// Copyright (c) 2025, 大连理工大学 (Dalian University of Technology)
//
// Licensed under the Mulan PSL v2.
// You can use this file according to the terms and conditions of the Mulan PSL v2.
// You may obtain a copy of the License at
//
//     http://license.coscl.org.cn/MulanPSL2
//
// THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
// EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. SEE THE MULAN PSL v2
// FOR MORE DETAILS.

#include "Import/BDFImport/BulkData/Property/PELASParser.h"

#include "gtest/gtest.h"

#include "DBManager/DBServiceFactory.h"
#include "DBManager/IService/Input/Property/IPELASService.h"

using namespace SG::DataStructure::FEM;
#include "Import/BDFImport/BDFParserBase.h"
using namespace SG::DBManager;
using namespace SG::Import;
extern std::shared_ptr<DBServiceFactory> DB_SERVICEFACTORY;
extern std::vector<std::string>          dividedEntryInfo;

class PELASParserTest : public ::testing::Test
{
  public:
    static void SetUpTestSuite ()
    {
        DB_SERVICEFACTORY->ClearDatabase ();
    }
};

TEST_F (PELASParserTest, ParseEntry1)
{
    std::vector<std::string> Entry = { "PELAS   14355893 200." };
    BDF::divideBulkEntry (Entry, dividedEntryInfo);
    SG::Import::BDF::BULKDATA::ParsePELAS (DB_SERVICEFACTORY, dividedEntryInfo);
    SG::DataStructure::FEM::PELASData data;

    ASSERT_TRUE (DB_SERVICEFACTORY->get<IPELASService> ()->FindById (14355893, data) == SG::DataStructure::Common::Status::STATUS_Success);

    ASSERT_TRUE (data.m_id == 14355893);
    ASSERT_TRUE (data.m_K == 200.0);
    ASSERT_TRUE (data.m_S == 0.0);
    ASSERT_TRUE (data.m_D == 0.0);
}
